|                                                                                                  | WHAT IS CLAIMED IS:                                                                               |
|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Sub                                                                                              |                                                                                                   |
| AL                                                                                               | A method comprising the steps of:                                                                 |
| 2                                                                                                | receiving a first request to access data from a first memory device;                              |
| 3                                                                                                | preparing the first request for the data for access through the first memory device;              |
| 4                                                                                                | providing a second request to access the data from a second memory device, wherein the            |
| 5                                                                                                | second request is provided concurrently with the step of preparing the first                      |
| 6                                                                                                | request;                                                                                          |
| 7                                                                                                | receiving a first notification that the data associated with the first request is available       |
| 8                                                                                                | from the second memory device; and                                                                |
| 9                                                                                                | terminating the first request, in response to the first notification.                             |
| _                                                                                                |                                                                                                   |
|                                                                                                  |                                                                                                   |
| 1<br>1                                                                                           | 2. The method as in Claim 1, wherein terminating the first request includes terminating the       |
| O<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J<br>J | first request in a memory controller before the first request is sent to the first memory device. |
| <b>1</b>                                                                                         | 3. The method as in Claim 1, wherein terminating the first request includes terminating data      |
| " 2<br>5<br>5<br>1                                                                               | received from the first memory device, wherein the data is associated with the first request.     |
|                                                                                                  | 4. The method as in Claim 3, wherein the data is terminated in a memory controller.               |
| 1                                                                                                | 5. The method as in Claim 1, wherein the data in the second memory device is coherent             |
| 2                                                                                                | with the data in the first memory device.                                                         |
|                                                                                                  |                                                                                                   |
| 1                                                                                                | 6. The method as in Claim 1, wherein the first memory device includes random access               |
| 2                                                                                                | memory.                                                                                           |



- device terminates the memory request in response to the termination request.
- 1 9. The method as in Claim 1, wherein the first request is generated by a client on a system
- 2 bus.
- 1 10. The method as in Claim 1, wherein the memory request includes a multiple target
- 2 memory request.
- 1 11. The method as in Claim 1, wherein the step of providing a second request includes:
- 2 providing the second request to a bus interface unit; and
- wherein the bus interface unit is coupled to the second memory device.

| 1                         | 12. | A method comprising the steps of:                                                           |
|---------------------------|-----|---------------------------------------------------------------------------------------------|
| 2                         |     | receiving a first request to read data from a memory device;                                |
| 3                         |     | preparing a second request, based upon the first request, for transmission to the memory    |
| 4                         |     | device;                                                                                     |
| 5                         |     | delivering a third request, based upon the first request, for data from a cache memory, the |
| 6                         |     | third request being delivered concurrently with the preparation of the second               |
| 7                         |     | request;                                                                                    |
| 8                         |     | providing, in response to the first request, data from the cache memory when the data       |
| 9                         |     | stored in the cache memory is coherent with the data stored in the memory device;           |
| 10                        |     | terminating the second request when the data is provided from the cache memory; and         |
| 11                        |     | providing, in response to the first request, data from the memory device when the data      |
| 12                        |     | stored in the cache memory is not coherent with the data stored in the memory               |
| ₫3                        |     | device.                                                                                     |
|                           | 13. | The method as in Claim 12, wherein the step of terminating the second request further       |
| TI.                       | 13. |                                                                                             |
| ₩2<br>₩                   |     | includes stopping delivery of the second request to the memory device.                      |
| 01 .                      |     |                                                                                             |
| <b>= 1</b>                | 14. | The method as in Claim 12, wherein the step of terminating the second request includes      |
|                           |     | further stopping data from the memory device from being provided in response to the         |
| $\overline{\mathbb{Q}}_3$ |     | first request.                                                                              |
| U                         |     |                                                                                             |
| ļub.                      |     |                                                                                             |
| 1                         | 15. | The method as in Claim 12, wherein a memory controller associated with the memory           |
| 2                         |     | device is used for the step of terminating the second request.                              |
|                           |     |                                                                                             |
| 1                         | 16. | The method as in Claim 12, wherein the first request is generated by a bus client.          |
|                           |     |                                                                                             |
|                           |     |                                                                                             |
| 1                         | 17. | The method as in Claim 15, wherein the client is a multiple target memory request.          |
|                           |     |                                                                                             |

- 1 18. The method as in Claim 12, wherein delivering a third request includes:
- delivering the third request to a bus interface; and
- wherein the bas interface unit is coupled to the cache memory.

| 1                                | 19. | A system comprising:                                                                          |
|----------------------------------|-----|-----------------------------------------------------------------------------------------------|
| 2                                |     | a data processor having:                                                                      |
| 3                                |     | an input/output buffer; and                                                                   |
| 4                                |     | cache memory to store data associated with a memory device;                                   |
| 5                                |     | a bus interface unit having a first input/output buffer coupled to the input/output buffer of |
| 6                                |     | the data processor, a second input/output buffer and a third input/output buffer,             |
| 7                                |     | said bus interface unit to:                                                                   |
| 8                                |     | determine a validity of data in said cache memory during a cache access; and                  |
| 9                                |     | provide a notification indicating data in said cache memory is valid, wherein said            |
| 10                               |     | notification identifies a first request;                                                      |
| 11                               |     | said memory device having an input/output buffer coupled, said memory device to               |
| 12                               |     | provide data associated with a first request;                                                 |
| ₫3                               |     | a bus controller having a first input/output buffer coupled to the input/output buffer of the |
| 4                                |     | data processor, a second input/output buffer coupled to the second input/output               |
| 13<br>14<br>15<br>14<br>16<br>17 |     | buffer of the bus interface unit and a third input/output buffer, said bus controller         |
| ₩<br>6                           |     | to:                                                                                           |
| <b>9</b> 17                      |     | receive said first request to access data in said memory device, wherein said                 |
|                                  |     | request is received from a bus client;                                                        |
| 18<br>9<br>120<br>121<br>122     |     | provide said first request to the memory controller;                                          |
| <b>1</b> 20 m                    |     | receive said data associated with said first request from said bus interface unit;            |
| <b>2</b> 1                       |     | the memory controller having a first input/output buffer coupled to the third input/output    |
| 22                               |     | buffer of the bus controller, a second input/output buffer coupled to the third               |
| 23                               |     | input/output buffer of the bus interface unit and a third input/output buffer                 |
| 24                               |     | coupled to the input/output buffer of the memory device, said memory controller               |
| 25                               |     | to:                                                                                           |
| 26                               |     | provide access to said memory device;                                                         |
| 27                               |     | receive said first request from said bus controller;                                          |
| 28                               |     | prepare said first request to access data from said memory device;                            |
| 29                               |     | provide a second request to said bus interface unit, wherein said second request is           |
| 30                               |     | to access data associated with said first request from said cache memory;                     |
| 31                               |     | receive said notification from said bus interface unit; and                                   |



- 25. The system as in Claim 19, wherein said memory controller further used to: assign a first identifier to said first request; and identify said first request from a plurality of pending requests using said first identifier.
- 26. The system as in Claim 19, said memory controller further used to: 1
- generate a second identifier using said notification; and 2

T 1

<u></u> 4 2

3

3 storing said identifier as part of a kill list, wherein said kill list identifies requests to be terminated. 4

1

2









- The system as in Claim 19, wherein said memory controller to terminate the first request 27. includes terminating data received from said memory device, wherein said data is
- associated with said first request. 3